/*
 * Copyright 2018 JDCLOUD.COM
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http:#www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * 云主机
 * 与主机操作相关的接口
 *
 * OpenAPI spec version: v1
 * Contact: 
 *
 * NOTE: This class is auto generated by the jdcloud code generator program.
 */


using System;
using System.Collections.Generic;
using System.Text;
using JDCloudSDK.Core.Service;

using JDCloudSDK.Vm.Model;
using JDCloudSDK.Core.Annotation;
using Newtonsoft.Json;

namespace  JDCloudSDK.Vm.Apis
{

    /// <summary>
    ///  
        ///         /// 修改一台云主机的属性。
        ///         /// 
        ///         /// 详细操作说明请参考帮助文档：
        ///         /// [修改实例名称](https://docs.jdcloud.com/cn/virtual-machines/modify-instance-name)
        ///         /// [自定义数据](https://docs.jdcloud.com/cn/virtual-machines/userdata)
        ///         /// [实例元数据](https://docs.jdcloud.com/cn/virtual-machines/instance-metadata)
        ///         /// 
        ///         /// ## 接口说明
        ///         /// - 支持修改实例的名称、描述、hostname、自定义数据、实例元数据。
        ///         /// 
    /// </summary>
    public class ModifyInstanceAttributeRequest : JdcloudRequest
    {
        ///<summary>
        /// 实例名称。长度为2\~128个字符，只允许中文、数字、大小写字母、英文下划线（\_）、连字符（-）及点（.），不能以（.）作为首尾。
        /// 
        ///</summary>
        public   string Name{ get; set; }
        ///<summary>
        /// 实例描述。256字符以内。
        /// 
        ///</summary>
        public   string Description{ get; set; }
        ///<summary>
        /// 实例hostname。
        /// **Windows系统**：长度为2\~15个字符，允许大小写字母、数字或连字符（-），不能以连字符（-）开头或结尾，不能连续使用连字符（-），也不能全部使用数字。不支持点号（.）。
        /// **Linux系统**：长度为2-64个字符，允许支持多个点号，点之间为一段，每段允许使用大小写字母、数字或连字符（-），但不能连续使用点号（.）或连字符（-），不能以点号（.）或连字符（-）开头或结尾。
        /// 
        ///</summary>
        public   string Hostname{ get; set; }
        ///<summary>
        /// 用户自定义元数据。
        /// 以 &#x60;key-value&#x60; 键值对形式指定，可在实例系统内通过元数据服务查询获取。最多支持40对键值对，且 &#x60;key&#x60; 不超过256字符，&#x60;value&#x60; 不超过16KB，不区分大小写。
        /// 注意：&#x60;key&#x60; 不要以连字符(-)结尾，否则此 &#x60;key&#x60; 不生效。
        /// 
        ///</summary>
        public List<Metadata> Metadata{ get; set; }

        ///<summary>
        /// 自定义脚本。
        /// 目前仅支持启动脚本，即 &#x60;launch-script&#x60;，须Base64编码且编码前数据长度不能超过16KB。
        /// **linux系统**：支持bash和python，编码前须分别以 &#x60;#!/bin/bash&#x60; 和 &#x60;#!/usr/bin/env python&#x60; 作为内容首行。
        /// **Windows系统**：支持 &#x60;bat&#x60; 和 &#x60;powershell&#x60; ，编码前须分别以 &#x60;&lt;cmd&gt;&lt;/cmd&gt;和&lt;powershell&gt;&lt;/powershell&gt;&#x60; 作为内容首、尾行。
        /// 
        ///</summary>
        public List<Userdata> Userdata{ get; set; }

        ///<summary>
        /// 地域ID。
        ///Required:true
        ///</summary>
        [Required]
        [JsonProperty("regionId")]
        public   string RegionIdValue{ get; set; }
        ///<summary>
        /// 云主机ID。
        ///Required:true
        ///</summary>
        [Required]
        public   string InstanceId{ get; set; }
    }
}